<template>
  <div class="divBox">
    <el-card class="box-card mb20">
      <div slot="header" class="clearfix">
        <router-link :to="{path:roterPre+'/accounts/reconciliation'}">
          <el-button size="mini" class="mr20 mb20" icon="el-icon-back">返回</el-button>
        </router-link>
        <!--<div class="filter-container">-->
          <!--<el-form :inline="true">-->
            <!--<el-form-item label="使用状态：" class="mr20">-->
              <!--<el-select v-model="tableFrom.status" placeholder="请选择评价状态" @change="getList">-->
                <!--<el-option label="全部" value="" />-->
                <!--<el-option label="未对账" value="0" />-->
                <!--<el-option label="已对账" value="1" />-->
              <!--</el-select>-->
            <!--</el-form-item>-->
            <!--<el-form-item label="时间选择：" class="mr10">-->
              <!--<el-date-picker-->
                <!--v-model="timeVal"-->
                <!--type="daterange"-->
                <!--align="right"-->
                <!--unlink-panels-->
                <!--format="yyyy 年 MM 月 dd 日"-->
                <!--value-format="yyyy/MM/dd"-->
                <!--range-separator="至"-->
                <!--start-placeholder="开始日期"-->
                <!--end-placeholder="结束日期"-->
                <!--:picker-options="pickerOptions"-->
                <!--@change="onchangeTime"-->
              <!--/>-->
            <!--</el-form-item>-->
            <!--&lt;!&ndash;<el-form-item label="优惠劵：" class="mr10">&ndash;&gt;-->
            <!--&lt;!&ndash;<el-input v-model="tableFrom.name" placeholder="请输入优惠劵" class="selWidth">&ndash;&gt;-->
            <!--&lt;!&ndash;<el-button slot="append" icon="el-icon-search" />&ndash;&gt;-->
            <!--&lt;!&ndash;</el-input>&ndash;&gt;-->
            <!--&lt;!&ndash;</el-form-item>&ndash;&gt;-->
          <!--</el-form>-->
        <!--</div>-->
      </div>
      <el-table
        v-loading="listLoading"
        :data="tableData.data"
        style="width: 100%"
        size="mini"
        class="table"
        highlight-current-row
      >
        <el-table-column type="expand">
          <template slot-scope="props">
            <el-form label-position="left" inline class="demo-table-expand demo-table-expands">
              <el-form-item label="收货人：">
                <span>{{ props.row.real_name | filterEmpty }}</span>
              </el-form-item>
              <el-form-item label="电话：">
                <span>{{ props.row.user_phone | filterEmpty }}</span>
              </el-form-item>
              <el-form-item label="地址：">
                <span>{{ props.row.user_address | filterEmpty }}</span>
              </el-form-item>
              <el-form-item label="商品总数：">
                <span>{{ props.row.total_num | filterEmpty }}</span>
              </el-form-item>
              <el-form-item label="支付状态：">
                <span>{{ props.row.pay_type | payTypeFilter }}</span>
              </el-form-item>
              <el-form-item label="支付时间：">
                <span>{{ props.row.pay_time | filterEmpty }}</span>
              </el-form-item>
              <el-form-item label="对账备注：">
                <span>{{ props.row.admin_mark | filterEmpty }}</span>
              </el-form-item>
            </el-form>
          </template>
        </el-table-column>
        <el-table-column
          prop="order_id"
          label="ID"
          width="60"
        />
        <el-table-column
          label="是否对账"
          min-width="100"
        >
          <template slot-scope="scope">
            <span>{{ scope.row.reconciliation_id | reconciliationFilter }}</span>
          </template>
        </el-table-column>
        <el-table-column
          prop="order_sn"
          label="订单编号"
          min-width="190"
        />
        <el-table-column
          label="商品信息"
          min-width="330"
        >
          <template slot-scope="scope">
            <div v-for="(val, i ) in scope.row.orderProduct" :key="i" class="tabBox acea-row row-middle">
              <div class="demo-image__preview">
                <el-image
                  :src="val.cart_info.product.image"
                  :preview-src-list="[val.cart_info.product.image]"
                />
              </div>
              <span class="tabBox_tit">{{ val.cart_info.product.store_name + ' | ' }}{{ val.cart_info.productAttr.sku }}</span>
              <span class="tabBox_pice">{{ '￥'+ val.cart_info.productAttr.price + ' x '+ val.product_num }}</span>
            </div>
          </template>
        </el-table-column>
        <el-table-column
          label="商品总价"
          min-width="150"
        >
          <template slot-scope="scope">
            <span>{{ getTotal(scope.row.orderProduct) }}</span>
          </template>
        </el-table-column>
        <el-table-column label="佣金金额" min-width="100">
          <template slot-scope="scope">
            <span>{{Number(scope.row.extension_one)+Number(scope.row.extension_two)}}</span>
          </template>
        </el-table-column>
        <el-table-column
          prop="pay_price"
          label="实际支付"
          min-width="100"
        />
        <el-table-column
          prop="total_postage"
          label="邮费"
          min-width="100"
        />
        <el-table-column
          prop="order_rate"
          label="手续费"
          min-width="100"
        />
        <el-table-column
          prop="create_time"
          label="下单时间"
          min-width="150"
        />
      </el-table>
      <div class="block mb20">
        <el-pagination
          :page-sizes="[10, 20, 30, 40]"
          :page-size="tableFrom.limit"
          :current-page="tableFrom.page"
          layout="total, sizes, prev, pager, next, jumper"
          :total="tableData.total"
          @size-change="handleSizeChange"
          @current-change="pageChange"
        />
      </div>
    </el-card>
    <el-card class="box-card">
      <el-table
        v-loading="listLoading"
        :data="tableDataRefund.data"
        style="width: 100%"
        size="mini"
        class="table"
        highlight-current-row
      >
        <el-table-column type="expand">
          <template slot-scope="props">
            <el-form label-position="left" inline class="demo-table-expand demo-table-expandss">
              <el-form-item label="订单号：">
                <span>{{ props.row.order.order_sn }}</span>
              </el-form-item>
              <el-form-item label="退款商品总价：">
                <span>{{ getTotalRefund(props.row.refundProduct) }}</span>
              </el-form-item>
              <el-form-item label="退款商品总数：">
                <span>{{ props.row.refund_num }}</span>
              </el-form-item>
              <el-form-item label="申请退款时间：">
                <span>{{ props.row.create_time | filterEmpty }}</span>
              </el-form-item>
              <el-form-item label="对账备注：">
                <span>{{ props.row.admin_mark | filterEmpty }}</span>
              </el-form-item>
            </el-form>
          </template>
        </el-table-column>
        <el-table-column
          prop="refund_order_id"
          label="ID"
          width="60"
        />
        <el-table-column
          label="退款单号"
          min-width="170"
        >
          <template slot-scope="scope">
            <span style="display: block;" v-text="scope.row.refund_order_sn" />
            <span v-show="scope.row.is_del > 0" style="color: #ED4014;display: block;">用户已删除</span>
          </template>
        </el-table-column>
        <el-table-column
          label="是否对账"
          min-width="100"
        >
          <template slot-scope="scope">
            <span>{{ scope.row.reconciliation_id | reconciliationFilter }}</span>
          </template>
        </el-table-column>
        <el-table-column
          prop="user.nickname"
          label="用户信息"
          min-width="130"
        />
        <el-table-column
          prop="refund_price"
          label="退款金额"
          min-width="130"
        />
        <el-table-column
          prop="nickname"
          label="商品信息"
          min-width="330"
        >
          <template slot-scope="scope">
            <div v-for="(val, i ) in scope.row.refundProduct" :key="i" class="tabBox acea-row row-middle">
              <div class="demo-image__preview">
                <el-image
                  :src="val.product.cart_info.product.image"
                  :preview-src-list="[val.product.cart_info.product.image]"
                />
              </div>
              <span class="tabBox_tit">{{ val.product.cart_info.product.store_name + ' | ' }}{{ val.product.cart_info.productAttr.sku }}</span>
              <span class="tabBox_pice">{{ '￥'+ val.product.cart_info.productAttr.price + ' x '+ val.product.product_num }}</span>
            </div>
          </template>
        </el-table-column>
        <el-table-column
          prop="serviceScore"
          label="订单状态"
          min-width="250"
        >
          <template slot-scope="scope">
            <span style="display: block">{{ scope.row.status | orderRefundFilter }}</span>
            <span style="display: block">退款原因：{{ scope.row.refund_message }}</span>
            <span style="display: block">状态变更时间：{{ scope.row.status_time }}</span>
          </template>
        </el-table-column>
      </el-table>
      <div class="block">
        <el-pagination
          :page-sizes="[20, 40, 60, 80]"
          :page-size="tableFrom.limit"
          :current-page="tableFrom.page"
          layout="total, sizes, prev, pager, next, jumper"
          :total="tableDataRefund.total"
          @size-change="handleSizeChangeRefund"
          @current-change="pageChangeRefund"
        />
      </div>
    </el-card>
  </div>
</template>

<script>
import { reconciliationOrderApi, reconciliationRefundApi } from '@/api/accounts'
import { roterPre } from '@/settings'
export default {
  name: 'Record',
  data() {
    return {
      roterPre: roterPre,
      chkName: '',
      chkNameRefund: '',
      isIndeterminate: true,
      resource: [],
      visible: false,
      timeVal: [],
      pickerOptions: {
        shortcuts: [{
          text: '最近一周',
          onClick(picker) {
            const end = new Date()
            const start = new Date()
            start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)
            picker.$emit('pick', [start, end])
          }
        }, {
          text: '最近一个月',
          onClick(picker) {
            const end = new Date()
            const start = new Date()
            start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
            picker.$emit('pick', [start, end])
          }
        }, {
          text: '最近三个月',
          onClick(picker) {
            const end = new Date()
            const start = new Date()
            start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
            picker.$emit('pick', [start, end])
          }
        }]
      },
      listLoading: true,
      tableData: {
        data: [],
        total: 0
      },
      tableDataRefund: {
        data: [],
        total: 0
      },
      tableFrom: {
        page: 1,
        limit: 10
        // data: '',
        // status: ''
      },
      ids: [],
      idsRefund: []
    }
  },
  mounted() {
    this.getList()
    this.getRefundList()
    if (this.$route.params.type === 0) {
      this.setTagsViewTitle()
    }
  },
  created() {
    this.tempRoute = Object.assign({}, this.$route)
  },
  methods: {
    isDisabled(row) {
      if (row.status !== 3) {
        return false
      }
      return true
    },
    // 具体日期
    onchangeTime(e) {
      this.timeVal = e
      this.tableFrom.data = this.timeVal ? this.timeVal.join('-') : ''
      this.getList()
      this.getRefundList()
    },
    getTotalRefund(row) {
      let sum = 0
      for (let i = 0; i < row.length; i++) {
        sum += row[i].product.cart_info.productAttr.price * row[i].refund_num
      }
      return sum
    },
    getTotal(row) {
      let sum = 0
      for (let i = 0; i < row.length; i++) {
        sum += row[i].cart_info.productAttr.price * row[i].product_num
      }
      return sum
    },
    // 列表
    getList() {
      this.listLoading = true
      reconciliationOrderApi(this.$route.params.id, this.tableFrom).then(res => {
        this.tableData.data = res.data.list
        this.tableData.total = res.data.count
        this.tableData.data.map((item) => {
          this.$set(item, { checked: false })
        })
        this.listLoading = false
      }).catch(res => {
        this.listLoading = false
        this.$message.error(res.message)
      })
    },
    pageChange(page) {
      this.tableFrom.page = page
      this.getList()
    },
    handleSizeChange(val) {
      this.tableFrom.limit = val
      this.chkName = ''
      this.getList()
    },
    // 退款列表
    getRefundList() {
      this.listLoading = true
      reconciliationRefundApi(this.$route.params.id, this.tableFrom).then(res => {
        this.tableDataRefund.data = res.data.list
        this.tableDataRefund.total = res.data.count
        this.listLoading = false
      }).catch(res => {
        this.listLoading = false
        this.$message.error(res.message)
      })
    },
    pageChangeRefund(page) {
      this.tableFrom.page = page
      this.getRefundList()
    },
    handleSizeChangeRefund(val) {
      this.tableFrom.limit = val
      this.getRefundList()
    },
    setTagsViewTitle() {
      const title = '查看订单'
      const route = Object.assign({}, this.tempRoute, { title: `${title}-${this.$route.params.id}` })
      this.$store.dispatch('tagsView/updateVisitedView', route)
    }
  }
}
</script>

<style lang="scss" scoped>
  .spBlock{
    cursor: pointer;
  }
  .check{
    color: #00a2d4;
  }
  .tabPop{
    /deep/ .el-popover{
      width: 100px !important;
    }
  }
  .fang{
    display: inline-block;
    position: relative;
    border: 1px solid #DCDFE6;
    border-radius: 2px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 14px;
    height: 14px;
    background-color: #fff;
    z-index: 1;
    -webkit-transition: border-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46),background-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46);
    transition: border-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46),background-color 0.25s cubic-bezier(0.71, -0.46, 0.29, 1.46);
  }
  .el-table /deep/.DisabledSelection .cell .el-checkbox__inner{
    margin-left: -30px;
    position:relative;
  }
  .el-table /deep/.DisabledSelection .cell:before{
    content:"全选";
    position:absolute;
    right:11px;
  }
  .demo-table-expands{
    /deep/ label {
      width: 84px !important;
      color: #99a9bf;
    }
  }
  .demo-table-expandss{
    /deep/ label {
      width: 110px !important;
      color: #99a9bf;
    }
  }
  .selWidth{
    width: 300px;
  }
  .el-dropdown-link {
    cursor: pointer;
    color: #409EFF;
    font-size: 12px;
  }
  .el-icon-arrow-down {
    font-size: 12px;
  }
  .tabBox_tit {
    width: 60%;
    font-size: 12px !important;
    margin: 0 2px 0 10px;
    letter-spacing: 1px;
    padding: 5px 0;
    box-sizing: border-box;
  }
</style>
